<template>
  <div>
    <h2>物流相关信息</h2>
    <div class="logistics-info-header">
      <div class="logistics-info-header-left">
        <div :class="classStyle[list.logisticsStatus]">
          {{ status[list.logisticsStatus] }}
        </div>
        <div class="logistics-company">{{ list.logisticsCompany }}</div>
        <div class="logistics-no">{{ list.logisticsNo }}</div>
      </div>
    </div>
    <ul class="logistics-info-list">
      <li v-for="(item, index) in list.logisticsInfo" :key="index">
        <div class="logistics-info-list-time">{{ item.time }}</div>
        <div class="logistics-info-list-content">{{ item.content }}</div>
      </li>
    </ul>
    <button v-vip="list.role" @click="msg">查看物流详情</button>
  </div>
</template>

<script>
export default {
  props: {
    list: {
      type: Object,
      default: () => ({}),
    },
  },
  data() {
    return {
      status: ["未发货", "已发货", "已签收", "未签收"],
      classStyle: [
        "logistics-status red",
        "logistics-status green",
        "logistics-status blue",
        "logistics-status yellow",
      ],
    }
  },
  methods: {
    msg() {
      alert("详情")
    },
  },
  directives: {
    // 自定义一个局部指令
    vip: {
      inserted(el, { value }) {
        value === "admin" || value === "gaochen"
          ? (el.style.display = "block")
          : (el.style.display = "none")
      },
      update(el, binding) {
        binding.value === "admin" || binding.value === "gaochen"
          ? (el.style.display = "block")
          : (el.style.display = "none")
      },
    },
  },
}
</script>

<style>
.logistics-info-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.logistics-info-header-left {
  display: flex;
  align-items: center;
}

.logistics-status {
  font-weight: bold;
  font-size: 16px;
}
.blue {
  color: #007bff;
}
.red {
  color: red;
}
.green {
  color: green;
}
.yellow {
  color: tomato;
}
.logistics-company,
.logistics-no {
  margin-left: 10px;
  font-size: 14px;
  color: #333;
}

.logistics-info-list {
  list-style: none;
  padding: 0;
  margin: 0;
  max-height: 230px;
  overflow-y: auto;
}

.logistics-info-list li {
  display: flex;
  margin-bottom: 10px;
}

.logistics-info-list-time {
  font-size: 12px;
  color: #999;
  width: 80px;
  text-align: right;
  margin-right: 10px;
}

.logistics-info-list-content {
  font-size: 14px;
  color: #333;
}
</style>
